// pages/good_list/index.js
import {
    getList
} from "../../request/api"
Page({

    /**
     * 页面的初始数据
     */
    data: {
        goodList: [],
        params: {
            pagenum: 1,
            pagesize: 10,
            cid: 5
        },
        //params就是请求数据时要传递的参数
        total: ""
    },

    /**
     * 生命周期函数--监听页面加载
     */
    onLoad: function (options) {
        // console.log(options);

        this.setData({
            "params.cid": options.cid
        })
        //把params作为要传递的请求数据的参数 在进入页面的时候修改cid
        this.getListData()

        //根据cid请求商品列表的数据


    },
    getListData() {

        getList(this.data.params).then(res => {
            console.log(res);
            this.setData({
                goodList: [...this.data.goodList, ...res.message.goods],
                //这里不能直接赋值 而是要用旧的数据拼上新的数据
                total: res.message.total
            })
        })
    },

    /**
     * 生命周期函数--监听页面初次渲染完成
     */
    onReady: function () {

    },

    /**
     * 生命周期函数--监听页面显示
     */
    onShow: function () {

    },

    /**
     * 生命周期函数--监听页面隐藏
     */
    onHide: function () {

    },

    /**
     * 生命周期函数--监听页面卸载
     */
    onUnload: function () {

    },

    /**
     * 页面相关事件处理函数--监听用户下拉动作
     */
    onPullDownRefresh: function () {
        console.log(111);
        this.setData({
            "params.pagenum": 1,
            goodList: []
        })
        //下拉刷新的时候 页码变为1 数据列表变成空
        this.getListData()

    },

    /**
     * 页面上拉触底事件的处理函数
     */
    onReachBottom: function () {
        console.log("触底了");
        let num = ++this.data.params.pagenum
        this.setData({
            "params.pagenum": num
        })

        if (this.data.goodList.length >= this.data.total) {
            wx.showToast({
                title: '已经到底了',
            })
            return false;
        }
        //如果列表的长度和 总数一样的时候 就证明没有数据 就弹一个提示 已经到底了 并且用return终止这个函数的执行 
        this.getListData()

    },
    //这是小程序自带的事件处理函数 只要触底就会触发


    //注意 如果要开启下拉刷新 要在全局的window选项中或者页面的配置中 开启一个
    // "enablePullDownRefresh":true
    // 全局的就是所有页面都开启 页面的话就是只有这个页面有其他页面没有
})